class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定，请勿修改，直接返回方法规定的值即可
     *
     * 
     * @param nums int整型vector 
     * @return int整型
     */
    int minNumberInRotateArray(vector<int>& nums) {
        int left = 0;
        int right =nums.size()-1;
        while(left<right)
        {
            int mid = (left+right)/2;
            if(nums[mid]>nums[right])
            {
                //此时的旋转点就在右边的数组
                left = mid+1;
            }
            else if(nums[mid]<nums[right])
            {
                //此时的mid到right是一段升序的数组，不存在旋转点
                right = mid;
            }
            else {
                //无法判断那一段为升序的数组
                right--;
            }
        }
        return nums[left];
    }
};